package com.huike.web.controller.review;


import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;


    /**
     * =========================================================新增数据============================================
     */
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult add(@PathVariable String name, @PathVariable Integer age, @PathVariable String sex) {
        if (reviewService.insertReview(name, age, sex) != 1) {
            return AjaxResult.error();
        }

        return AjaxResult.success("成功插入:1条数据");
    }

    @PostMapping("/saveData2")
    public AjaxResult addTwo(@RequestBody Review review) {
        if (reviewService.insertReviewTwo(review) != 1) {
            return AjaxResult.error();
        }
        return AjaxResult.success("成功插入:1条数据");

    }

    /**
     * =========================================================删除数据=============================================
     */

    @PostMapping("/update")
    public AjaxResult update(@RequestBody Review review) {
        if (reviewService.updateReview(review) != 1) {
            return AjaxResult.error();
        }
        return AjaxResult.success("修改成功!");


    }

    /**
     * =========================================================修改数据=============================================
     */

    @DeleteMapping("/remove/{id}")
    public AjaxResult delete(@PathVariable Long id) {
        if (reviewService.deleteReview(id) != 1) {
            return AjaxResult.error();
        }
        return AjaxResult.success("成功删除:1条数据");
    }
    /**=========================================================查询数据=============================================*/

    @GetMapping("/getById")
    public AjaxResult getById( Long id){
      Review review=  reviewService.getById(id);
        if (review == null) {
            return AjaxResult.error();
        }
        return AjaxResult.success("操作成功!",review);
    }


    @GetMapping("/getDataByPage")
    public TableDataInfo getDataByPage(){
       List<Review> list= reviewService.selectList();
       return getDataTablePage(list);
    }
}